# Copyright (C) 2012-2015 Free Software Foundation, Inc.

# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
# 
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
# 
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  

#
# Some generic xtensa tests
#
if [istarget xtensa*-*-*] then {
    gas_test_error "j_too_far.s" "" "Check for jump out of range error"

    set testname "j_too_far.s: error line number reporting"
    gas_start "j_too_far.s" ""
    set x1 0
    while 1 {
        expect {
            -re ":4: Error:.*out of range"      { set x1 1 }
            timeout                             { perror "timeout\n"; break }
            eof                                 { break }
        }
    }
    gas_finish
    if [all_ones $x1] then { pass $testname } else { fail $testname }


    gas_test "entry_misalign.s" "" "" "Xtensa Entry misalignment"
    set testname "entry_misalign.s: Force entry misalignment"
    objdump_start_no_subdir "a.out" "-d -j .text"
    set x1 0
    while 1 {
	expect {
	    -re "^.*2:.*entry" { set x1 1 }
	    timeout            { perror "timeout\n"; break }
	    eof                { break }
	}
    }
    objdump_finish
    if [all_ones $x1] then { pass $testname } else { fail $testname }


    gas_test "entry_misalign2.s" "" "" "Xtensa Entry misalignment(2)"
    set testname "entry_misalign2.s: Force entry misalignment(2)"
    objdump_start_no_subdir "a.out" "-d -j .text"
    set x1 0
    while 1 {
	expect {
	    -re "^.*2:.*entry" { set x1 1 }
	    timeout            { perror "timeout\n"; break }
	    eof                { break }
	}
    }
    objdump_finish
    if [all_ones $x1] then { pass $testname } else { fail $testname }

    gas_test_error "entry_align.s" "" "Xtensa entry alignment error"

    gas_test "loop_misalign.s" "" "" "Xtensa Loop misalignment"
    set testname "loop_misalign.s: Force loop misalignment"
    objdump_start_no_subdir "a.out" "-d -j .text"
    set x1 0
    while 1 {
	expect {
	    -re "^.*0:.*loop" { set x1 1 }
	    timeout            { perror "timeout\n"; break }
	    eof                { break }
	}
    }
    objdump_finish
    if [all_ones $x1] then { pass $testname } else { fail $testname }


    gas_test "loop_align.s" "" "" "Xtensa autoalign loop"
    set testname "loop_align.s: autoalign loop"
    objdump_start_no_subdir "a.out" "-d -j .text"
    set x1 0
    while 1 {
	expect {
	    -re "^.*2:.*loop" { set x1 1 }
	    timeout            { perror "timeout\n"; break }
	    eof                { break }
	}
    }
    objdump_finish
    if [all_ones $x1] then { pass $testname } else { fail $testname }

    run_dump_test "short_branch_offset"
    run_dump_test "pcrel"
    run_dump_test "weak-call"
    run_dump_test "jlong"
    run_dump_test "trampoline"
    run_dump_test "first_frag_align"
    run_dump_test "auto-litpools"
}

if [info exists errorInfo] then {
    unset errorInfo
}
